一 前言
记录javascript语言object类型的一些问题。
1. typeof []; // object
2. typeof {};// object
3. typeof null; //object
这里讲的是第二种情况。
二 正文
1.for...in 会遍历原型链上的属性
class Super{
constructor(val){
this.value=val;
}
};
const suber = {
value:'suber'
};
suber.prototype = new Super('super');
for(attr in suber){
const val = suber[attr]
console.log('attr-val=>',attr,val); //attr-val=> value suber attr-val=> prototype Super {value: "super"}
}
这个问题很多人都应该知道。解决的办法也很多:
1) 使用hasOwnProperty(attr) 来取自有属性的值
2) 使用Object.keys(object) 来取得所有的自有属性key,然后object[key]来取得value
2.for...in 遍历的顺序不能保证
Properties order in objects is not guaranteed in JavaScript; you need to use an Array.
for...in 遍历的顺序是按道理来讲是按照出现的先后顺序,但是各家浏览器遍历顺序有所不同。
Chrome Opera 中使用 for-in 语句遍历对象属性时会遵循一个规律,它们会先提取所有 key 的 parseFloat 值为非负整数的属性, 然后根据数字顺序对属性排序首先遍历出来,然后按照对象定义的顺序遍历余下的所有属性。其它浏览器则完全按照对象定义的顺序遍历属性。
所以,顺序这种事,还是要用数组来保证。
详细请参考:JS对象遍历顺序
三 后记
参考链接:JS对象遍历顺序
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。